默认初始化容量10(底层先创建了一个长度为0的数组,当添加第一个元素的时候,初始化容量10)
集合底层是一个 Object[] 数组
构造方法
new ArrayList();
new ArrayList(20);
ArrayList 集合的扩容:增长到原容量的 1.5 倍
ArrayList 集合底层是数组,怎么优化
- 尽可能少的扩容。因为数组扩容效率比较低,建议在使用 ArrayList 集合的时候预估计元素的个数,给定一个初始化容量
数组优点:
- 检索效率比较高(每个元素占用空间大小相同,内存地址是连续的,知道首元素内存地址,然后知道下标,通过数学表达式计算出元素的内存地址,所以检索效率最高)
数组缺点:
- 随机增删元素效率比较低
- 数组无法存储大数据量(很难找到一块非常巨大的连续的内存空间)
向数组末尾添加元素,效率很高,不受影响
这么多集合,用哪个集合最多?
- ArrayList 集合,因为往数组末尾添加元素,效率不受影响。另外,我们检索/查找某个元素的操作比较多。
ArrayList 集合是非线程安全的(不是线程安全的集合)
1 | import java.util.ArrayList; |